### (12) INTERNATIONAL APPLICATION PUBLISHED UNDER THE PATENT COOPERATION TREATY (PCT)

### (19) World Intellectual Property Organization International Bureau



10/537577

(43) International Publication Date 24 June 2004 (24.06.2004)

PCT

(10) International Publication Number WO 2004/054104 A1

- (51) International Patent Classification7:
- H03K 7/08
- (21) International Application Number:

PCT/IB2003/005396

(22) International Filing Date:

25 November 2003 (25.11.2003)

(25) Filing Language:

English

(26) Publication Language:

English

(30) Priority Data:

60/432,300

10 December 2002 (10.12.2002) US

- (71) Applicant (for all designated States except US): KONIN-KLIJKE PHILIPS ELECTRONICS N.V. [NL/NL]; Groenewoudseweg 1, NL-5621 BA Eindhoven (NL).
- (72) Inventor; and
- (75) Inventor/Applicant (for US only): LI, Qiong, M. [US/US]; P.O. Box 3001, Briarcliff Manor, NY 10510-8001 (US).
- (74) Common Representative: KONINKLIJKE PHILIPS ELECTRONICS N.V.; c/o Aaron Waxler, P.O. Box 3001, Briarcliff Manor, NY 10510-8001 (US).

- (81) Designated States (national): AE, AG, AL, AM, AT, AU, AZ, BA, BB, BG, BR, BY, BZ, CA, CH, CN, CO, CR, CU, CZ, DE, DK, DM, DZ, EC, EE, EG, ES, FI, GB, GD, GE, GH, GM, HR, HU, ID, IL, IN, IS, JP, KE, KG, KP, KR, KZ, LC, LK, LR, LS, LT, LU, LV, MA, MD, MG, MK, MN, MW, MX, MZ, NI, NO, NZ, OM, PG, PH, PL, PT, RO, RU, SC, SD, SE, SG, SK, SL, SY, TJ, TM, TN, TR, TT, TZ, UA, UG, US, UZ, VC, VN, YU, ZA, ZM, ZW.
- (84) Designated States (regional): ARIPO patent (BW, GH, GM, KE, LS, MW, MZ, SD, SL, SZ, TZ, UG, ZM, ZW), Eurasian patent (AM, AZ, BY, KG, KZ, MD, RU, TJ, TM), European patent (AT, BE, BG, CH, CY, CZ, DE, DK, EE, ES, FI, FR, GB, GR, HU, IE, IT, LU, MC, NL, PT, RO, SE, SI, SK, TR), OAPI patent (BF, BJ, CF, CG, CI, CM, GA, GN, GQ, GW, ML, MR, NE, SN, TD, TG).

#### **Declaration under Rule 4.17:**

as to applicant's entitlement to apply for and be granted a patent (Rule 4.17(ii)) for all designations

### Published:

with international search report

For two-letter codes and other abbreviations, refer to the "Guidance Notes on Codes and Abbreviations" appearing at the beginning of each regular issue of the PCT Gazette.

(54) Title: HARDWARE/SOFTWARE IMPLEMENTATION OF A PWM WITH ENHANCED FEATURES USING A STAN-DARD MICROPROCESSOR

(57) Abstract: A method and apparatus is provided to generate a pulse-width modulated (PWM) waveform with enhanced features in accordance with a pre-determined protocol using a standard microprocessor. The method and apparatus is able to handle both variable on/off-timing control and multiple-event interrupts. The PWM functions of the present invention are implemented by software in the microprocessor that handles not only on/off events controlled by external pins, but is programmable on/off timing as well.





WO 2004/054104

0 6 JUN 2005 PCT/IB2003/005396

# HARDWARE/SOFTWARE IMPLEMENTATION OF A PWM WITH ENHANCED FEATURES USING A STANDARD MICROPROCESSOR

5

10

15

20

25

The present invention relates to pulse-width-modulation (PWM) waveform generators. More particularly, the present invention relates to an intelligent, programmable PWM generator with enhanced features implemented using standard modules in a microprocessor. The PWM of the present invention is able to handle both variable on/off-timing control and multiple-event interrupts.

A PWM control signal is widely used in power converters with a PWM control to turn on and off power switches. Examples of PWM generators include: a hardware-implemented, duty-cycle-modulated PWM, as illustrated in FIG. 1; a current control circuit with critical-boundary modulation, as illustrated in FIG. 2; and, a software-controlled PWM generator with programmable on and off periods, as illustrated in FIG. 5.

A simple PWM generator circuit with a variable pulse-width and fixed-period control is illustrated in FIG. 1. The control-signal waveforms are illustrated in FIG 2. The inputs to the circuit consist of one saw-toothed signal, Vsaw, and a reference voltage, Verr, which is a fixed voltage for an open-loop circuit and an error voltage from the output of a compensation network for a closed-loop circuit. The PWM signal becomes low when the saw-toothed voltage reaches Verr as illustrated in FIG. 2. The pulse-width of the PWM is controlled by Verr.

A PWM generator of critical boundary control with peak-current-detect off and zero-current-detect on is illustrated in FIG. 3. The control waveforms are illustrated in FIG. 4. The PWM becomes low when a peak current is detected and the PWM becomes high again when a zero current is detected (ZCD). The PWM can have a variable pulse-width and period.

In addition to PWM generators with hardware implementation in conventional analog circuits, a commonly used PWM generator available in many microprocessors is illustrated in FIG. 5. The microprocessor calculates the switching period and on-time of the PWM signal and pre-loads the counter registers before the next period. The output of a PWM generator is illustrated in FIG. 6. However, in the implementation illustrated, the software cannot handle the external on or off signal as a regular control signal (e.g. in each period continuously).

Many applications require combined features from known PWM generators. For example, in existing peak current mode controlled circuits, the PWM can be forced off by a peak current detection, forced-on by a zero current detection while at the same time a maximum on time, minimum off time, and maximum off time must be satisfied.

10

15

20

25

Another example of an application requiring combined features of known PWM generators is a digital-controlled circuit that requires two-mode operations depending on load conditions -- e.g. current mode control under a heavy load and voltage mode control under a light load. In a current mode control, the on and off is controlled by external forced on and forced off, in voltage mode control, the on and off is calculated by a software in a microprocessor with a programmable on and off timing.

Another example is a power factor-correction circuit with programmable on-time and zero detection off-time control.

FIG. 7 illustrates a block diagram of a standard timer. Two parameters are preloaded in the timer: period and compare value. The timer automatically reloads timing parameters when the previous counted period is reached or a reload command is sent from the software. The timer starts counting when the counter is preloaded and the enable signal is high. An interrupt signal can be generated when the compared value is reached or the period value is reached. FIG. 8 illustrates the output waveform of the standard timer illustrated in FIG. 7.

None of the prior art PWM devices provides this combination of features in a digitally-controlled circuit using a microprocessor.

Thus, a PWM generator is needed with enhanced features that are implemented in a microprocessor with a software and having standard hardware peripherals. The PWM functions of the present invention are implemented by a software in a microprocessor that handles not only on or off events controlled by external pins, as in FIGs. 1 and 3, but is also programmable on and off timing as illustrated in FIG. 5.

A block diagram of a generic PWM generator according to a preferred embodiment of the present invention has on/off time control and multiple-event on/off actions as illustrated in FIG. 9. In this preferred embodiment, the PWM function with enhanced features uses standard modules in a microprocessor and is implemented by a hardware/software interaction in a microprocessor. No extra hardware is needed in the implementation. The number of force-on and force-off events depends on application requirements and the number of pins can be more than the two pins that are illustrated in FIG. 9.

- FIG. 1 illustrates a simple variable pulse-width and fixed-period control circuit.
- FIG. 2 illustrates control waveforms with a circuit illustrated in FIG. 1.
- FIG. 3 illustrates a control circuit with peak current off and zero current on.
- FIG. 4 illustrates control-signal waveforms with the circuit illustrated in FIG 3.
- FIG. 5 illustrates a block diagram of a commonly-used PWM generator in MCU.
- FIG. 6 illustrates the PWM output waveform of the generator illustrated in FIG. 5.
- FIG. 7 illustrates a block diagram of a standard timer.
- FIG. 8 illustrates the output of a standard timer.

5

10

15

25

30

- FIG. 9 illustrates a block diagram of a generic PWM generator with on and off time controls and multiple-event interrupts.
- FIG. 10 illustrates a block diagram of a PWM generator using standard units having enhanced features, according to an embodiment of the present invention.
  - FIG. 11 illustrates a flow chart of multiple-event interrupts for a PWM generator.

An implementation block diagram of a PWM according to a preferred embodiment of the present invention is illustrated in FIG. 10. As illustrated, the PWM generator of the present invention has two parts: a programmable on-and-off-control part 102 and a multiple-event-interrupts part 103. The programmable on-off-control part 102 is implemented by a first and second standard timer in a microprocessor. The multiple-event-interrupts part 103 is implemented by multiple interrupt routines in the software. The programmable PWM generator is controlled by hardware/software interactions.

In a preferred embodiment of the present invention, the two standard timers that are used in the programmable on-off-control part 102 are used for an on-time control 100 and an off-time control 101. These two controls function alternatively. The on-time control 100 is enabled when the PWM is high and the off-time control 101 is enabled when the PWM is low. The on-time control 100 sets the PWM to low when the min\_on time is exceeded and either a force\_off or a max\_on event is triggered. The off-time control sets the PWM to high when the min\_off time is exceeded and either a force\_on or a max\_off event is triggered. The timing parameters are pre-loaded in the inactive control when the other control is active, so there is no delay involved in this loading process.

FIG. 9 is a block diagram of a generic PWM according to the present invention. Illustrated are four registers and two events that can be externally or programmatically controlled (Force\_on and Force\_off). A pre-determined protocol for a PWM is the on-off pulse and period width(s) and the order of producing these on/off pulses, e.g., a specification for a series of pulses having a given width and period. For example, the period 90 is determined by the value of the Max\_on register and the Max\_off register or (Max\_on register + Max\_off register). The on-width 92 is determined by the value of the Max\_off register. In a given protocol, Force\_on and Force\_off events can override the register values to a certain extent within a minimum on and maximum on, and minimum off and maximum off period, as illustrated in FIG. 11.

FIG. 11 illustrates a flow chart 120 of a preferred embodiment of the multiple-event-interrupts part 103 that implements a pre-determined protocol for a series of on/off pulses that is produced by a PWM generatorError! Reference source not found. The interrupts associated with this pre-determined protocol are implemented by interrupt-handling software routines resident in a microprocessor. In the preferred embodiment of the programmable on/off control 118, illustrated in FIG. 11, four timer registers are provided 118 two for the timer 1 and the timer 2. Six events can be triggered 119: four by the programmable on/off control software and two externally. Keeping in mind that the timers are active alternately -- meaning that the performance of a. and b. below alternates -- in a preferred embodiment, the flow of processing by the multiple-event interrupts processor 103 is as follows:

a. If either a force\_off action occurs (int5 is triggered) or timer1 has been on longer than Tmax\_on (int2 is triggered) then int1 is tested at step 111 until it is triggered by the compare value reaching Tmin\_on. Then, at step 112 the PWM is set to low or off. Following step 112, at step 113 timer2 is turned on, timer 1 is turned off, int6=force on is enabled, and int5=force off is disabled.

b. If either a force\_on action occurs (int6 is triggered) or timer2 has been off longer than Tmax\_off (int4 is triggered), then int3 is tested at step 115 until it is triggered by the compare value reaching Tmin\_off. Then, at step 116 the PWM is set to high or turned on. Following step 116, at step 117 timer1 is turned on, timer 2 is turned off, int5=force\_off is enabled, and int6=force\_on is disabled.

When some of the events are not required by an application, those events can be disabled easily in the software.

The PWM implementation of a preferred embodiment of the present invention employs standard peripherals of a microprocessor without requiring any special units or extra hardware thus providing maximum flexibility as a PWM generator.

The PWM of a preferred embodiment has the following features:

• Programmable min-on control

5

10

15

20

25

30

- Programmable max-on control
- Programmable min-off control
- Programmable max-off control
- Multiple force-off events control, programmable or external
- Multiple force-on events control, programmable or external
- On/off timing can involve all or some of the parameters or events above.
- All events can be triggered in every PWM period continuously
- No delay time for pre-loading timer registers

While the invention has been explained with reference to specific embodiments of the invention, the explanation is presented by way of illustration only and not in any limiting sense. The invention scope is not restricted to the software and hardware structure described above but includes various modifications and variations that would be apparent to one skilled in the art. Such variations are not to be regarded as a departure from the spirit and scope of the invention, and all such modifications are intended to be included within the scope of the following claims.

### CLAIMS:

5

10

15

20

25

1. A PWM waveform-generator apparatus in which a series of pre-determined pulse widths are modulated in accordance with a pre-determined protocol, comprising:

means for generating a plurality of on/off timing-based interrupts;

means for generating a force on/off action-based interrupt having a programmable control:

means for generating a force on/off action-based interrupt having an external control; and,

means for interpreting said generated plurality of timing-based interrupts and said at least one action-based interrupt such that the series of pulse widths of the PWM waveform generator are modulated in accordance with said protocol.

2. The PWM waveform-generator apparatus of claim 1, wherein:

the means for generating a plurality of on/off timing-based interrupts is a programmable on-off-control part;

the means for generating a force on/off action-based interrupt having a programmable control is the programmable on-off control part;

the means for generating a force on/off action-based interrupt having an external control is selection from the group consisting of an external force\_on action and an external force\_off action; and,

the interpreting means is a multiple-event-interrupts part comprising a software interrupt routine for handling each timing-based and action-based interrupt.

3. The PWM waveform generator apparatus of claim 2, wherein said programmable on-off-control part comprises:

an on-time control comprising a first timer and a first comparator; and
an off-time control comprising a second timer and second comparator,
wherein the on-time control is enabled for a first period and the off-time control is disabled
when the PWM is high and the off-time control is enabled for a second period and the on-

time control is disabled when the PWM is low, such that the first and second control are alternately enabled and disabled.

4. The PWM waveform generator apparatus of claim 3, wherein: for on/off timing said protocol comprises at least one of:

5

10

15

25

30

- a programmable on-pulse width Min on parameter control,
- a programmable on-period Max\_on parameter control,
- a programmable off-pulse width Min\_off parameter control,
- a programmable off-period Max off parameter control,

at least one event control selected from a programmable event control for triggering a force-off event and an external event control for triggering a force-off event,

> at least one event control selected from a programmable event control for triggering a force-on event and an external event control for triggering a force-on event,

wherein at least one of a force-on event and a force-off event can be triggered in an onperiod and in an off-period.

- 5. The PWM waveform-generator apparatus of claim 4, wherein:
  the first timer and second timer respectively comprises a first and third register;
  the first and second comparator respectively comprises a second and fourth register;
  wherein, when the on-time control is enabled,
  - a. the second register has been pre-loaded by the on-time control with a compare value equal to a pre-determined minimum on-width (minimum on-time Min\_on) of the PWM, the first register has been pre-loaded with a predetermined maximum on-width (maximum on-time Max\_on) of the PWM such that there is no delay time for loading said first and second register,
  - b. a first interrupt is triggered by the first comparator when the second register equals the compare value and a second interrupt is triggered by the first timer when the first register equals a pre-determined first period, at least one action-based interrupt can be triggered at least once during one period of the PWM according to the pre-determined protocol, thereby turning off the PWM by the on-time control when at least one of the

second interrupt and the at least one action-based interrupt is triggered and the first interrupt is triggered, and

when the off-time control is enabled

c. the fourth register has been pre-loaded with a compare value equal to a predetermined minimum off-width (minimum off-time Min\_off) of the PWM, the third register has been pre-loaded with a predetermined maximum off-width (maximum off-time Max\_off) of the PWM such that there is no delay time for loading said third and fourth register,

- d. a third interrupt is triggered by the second comparator when the fourth register equals the compare value and a fourth interrupt is triggered by the second timer when the third register equals the pre-determined second period, at least one action-based interrupt can be triggered at least once during one period of the PWM according to the pre-determined protocol, thereby turning on the PWM by the off-time control when at least one of the fourth interrupt and theat least one action-based interrupt is triggered and the third interrupt is triggered.
  - 6. A microprocessor for performing the programmable on-off control and the software interrupt routines as claimed in claim 2.
- 7. A method of programmable control of a PWM generator in which a signal is modulated as a series of on/off pulses each having a width and a period in accordance with a pre-determined protocol, comprising the steps of:

providing a pre-determined protocol for a series of pulse widths and periods;

generating a plurality of on/off timing-based interrupts in accordance with the provided protocol;

generating at least one force on/off action-based interrupt in accordance with the provided protocol;

interpreting said generated plurality of timing-based interrupts and said at least one action-based interrupt in accordance with said protocol.

25

5

- 8. The method of claim 7, wherein:
  - the step of generating a plurality of on/off interrupts further comprises the steps of:
  - a. providing a programmable-on-off-control part, and
- b. controlling the generation of said plurality of on/off timing-based interrupts
  by the provided programmable on-off control part;

the step of generating at least one force on/off action-based interrupt further comprises at least one of the steps of:

- c. generating the at least one force on/off action-based interrupt by the provided programmable on-off control part;
  - d. performing the substeps of:
    - 1. providing an external control for the generation of the at least one force on/off action-based interrupt; and
    - 2. generating the at least one force on/off action-based interrupt by the provided external control.

15

10

- 9. The method of claim 8, wherein the interpreting step further comprises the steps of:
  - e. providing a multiple event-interrupts part; and
- f. controlling the interpretation of at least one action-based interrupt by the provided multiple event-interrupts part.

1/5



FIG. 1



FIG. 2



FIG. 3

2/5







FIG. 6



FIG. 7 PRIOR ART





FIG. 9



FIG. 10



FIG. 11

## INTERNATION SEARCH REPORT

A. CLASSIFICATION OF SUBJECT MATTER IPC 7 H03K7/08 10/5375**77** According to International Patent Classification (IPC) or to both national classification and IPC **B. FIELDS SEARCHED** Minimum documentation searched (classification system followed by classification symbols) IPC 7 H03K Documentation searched other than minimum documentation to the extent that such documents are included in the fields searched Electronic data base consulted during the international search (name of data base and, where practical, search terms used) EPO-Internal, PAJ C. DOCUMENTS CONSIDERED TO BE RELEVANT Relevant to claim No. Citation of document, with indication, where appropriate, of the relevant passages Category US 2002/180545 A1 (BOWLING STEPHEN A) 1-4,6-9 X 5 December 2002 (2002-12-05) paragraph '0024! - paragraph '0040!; figures 2,3 US 5 298 871 A (SHIMOHARA KAZUNARI) 1-9 A 29 March 1994 (1994-03-29) column 4, line 22 -column 6, line 9; figures 3,4 US 2002/136290 A1 (HOUGHTON WILLIAM G) 1-9 Α 26 September 2002 (2002-09-26) whole document US 6 421 382 B1 (HAYAKAWA KAZUYOSHI) 1-9 A 16 July 2002 (2002-07-16) figures 1,2 -/--Further documents are listed in the continuation of box C. Patent family members are listed in annex. X Special categories of cited documents: "T" later document published after the International filing date or priority date and not in conflict with the application but "A" document defining the general state of the art which is not considered to be of particular relevance cited to understand the principle or theory underlying the invention "E" earlier document but published on or after the international "X" document of particular relevance; the claimed invention cannot be considered novel or cannot be considered to filing date "L" document which may throw doubts on priority claim(s) or which is cited to establish the publication date of another citation or other special reason (as specified) involve an inventive step when the document is taken alone "Y" document of particular relevance; the claimed invention cannot be considered to involve an inventive step when the document is combined with one or more other such docu-\*O\* document referring to an oral disclosure, use, exhibition or ments, such combination being obvious to a person skilled other means in the art. document published prior to the International filing date but later than the priority date claimed "&" document member of the same patent family Date of the actual completion of the international search Date of mailing of the international search report 25/02/2004 17 February 2004 Name and mailing address of the ISA Authorized officer European Patent Office, P.B. 5818 Patentlaan 2

Form PCT/ISA/210 (second sheet) (July 1892)

NL - 2280 HV Rliswijk Tel. (+31-70) 340-2040, Tx. 31 651 epo nl,

Fax: (+31-70) 340-3016

Santos, P

| C (Continue | etion) DOCUMENTS CONSIDERED TO BE RELEVANT                                                                                                      |                   |     |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----|
| Category °  | Citation of document, with indication, where appropriate, of the relevant passages                                                              | Relevant to claim | No. |
| A           | PATENT ABSTRACTS OF JAPAN vol. 2000, no. 03, 30 March 2000 (2000-03-30) & JP 11 345033 A (FUJIKURA LTD), 14 December 1999 (1999-12-14) abstract | 1-9               |     |
|             |                                                                                                                                                 |                   |     |
|             |                                                                                                                                                 |                   |     |
|             |                                                                                                                                                 |                   |     |
|             |                                                                                                                                                 |                   |     |
|             |                                                                                                                                                 |                   |     |
|             |                                                                                                                                                 |                   |     |

### INTERNATIONAL SEARCH REPORT

|                                        | Int | ion on patent family members |          |                         | F E | B 03/05396               |  |
|----------------------------------------|-----|------------------------------|----------|-------------------------|-----|--------------------------|--|
| Patent document cited in search report |     | Publication date             |          | Patent family member(s) |     | Publication date         |  |
| US 2002180545                          | A1  | 05-12-2002                   | NONE     |                         |     |                          |  |
| US 5298871                             | A   | 29-03-1994                   | JP<br>JP | 2885256<br>5176547      | -   | 19-04-1999<br>13-07-1993 |  |
| US 2002136290                          | A1  | 26-09-2002                   | WO       | 02078184                | A2  | 03-10-2002               |  |
| US 6421382                             | B1  | 16-07-2002                   | JP<br>DE | 2001016081<br>10031642  |     | 19-01-2001<br>15-02-2001 |  |
| JP 11345033                            | A   | 14-12-1999                   | NONE     |                         |     |                          |  |

Application No